<template>
	<div>
		<div class="container">
			<div class="handle-box">
                <el-input v-model="realName" placeholder="搜索" class="handle-input mr10"></el-input>
				<!-- <el-button color="#1c84c0" :icon="Search" @click="handleSearch">查询</el-button> -->
                <el-button-group class="ml-4">
                    <el-button color="#1c84c0"  @click="open">添加</el-button>
                    <el-button type="danger"  @click="handleAllDelete">批量删除</el-button>
                </el-button-group>
			</div>
<<<<<<< HEAD
			<el-table ref="multipleTableRef"  :data="tableData"   style="width: 100%;" height="380" @selection-change="handleSelectionChange">
                <el-table-column   type="selection" width="30" />
=======
			<el-table ref="multipleTableRef"  
			:header-cell-style="{color:'#2A62BC'}"
			size="small"
			:data="tableData"   style="width: 100%;" height="380" @selection-change="handleSelectionChange">
                <el-table-column   type="selection" width="35" />
>>>>>>> c088509ecc2282a34d0b932f6925d649261c336d
				<el-table-column  prop="id" label="序号"  ></el-table-column>
				<el-table-column prop="privilegeName" label="权限名"></el-table-column>
                <el-table-column prop="privilegeDescription" label="权限描述"></el-table-column>
				<el-table-column label="操作" width="220" align="center" >
					<template #default="scope">
                        <el-button-group class="ml-4">
<<<<<<< HEAD
                        <!-- <el-button text :icon="Edit" @click="handleEdit(scope.$index,scope.row)" v-permiss="2"></el-button> -->
=======
>>>>>>> c088509ecc2282a34d0b932f6925d649261c336d
                        <el-tooltip content="修改" placement="top" effect="light" >
						<el-button text :icon="Edit" @click="open(scope.$index,scope.row)" ></el-button>
					</el-tooltip>
					<el-tooltip content="删除" placement="top" effect="light" >
						<el-button text :icon="Delete" class="red" @click="handleDelete(scope.$index)" ></el-button>
					</el-tooltip> 
					<el-tooltip content="分配菜单" placement="top" effect="light" >
<<<<<<< HEAD
                        <el-button text     @click="allocationMenu(scope.$index,scope.row)"><i class="iconfont icon-share4 blue"></i></el-button>
=======
                        <el-button text   @click="allocationMenu(scope.$index,scope.row)"><i class="iconfont icon-share4 blue"></i></el-button>
>>>>>>> c088509ecc2282a34d0b932f6925d649261c336d
                    </el-tooltip>    
					</el-button-group>
					</template>
				</el-table-column>
			</el-table>
			<div class="pagination">
				<el-pagination
				    :current-page="query.pageIndex"
					:page-size="query.pageSize"
					:page-sizes="[5, 10, 15, 20]"
<<<<<<< HEAD
					:small="small"
=======
					size="small"
>>>>>>> c088509ecc2282a34d0b932f6925d649261c336d
					layout="total, sizes, prev, pager, next, jumper"
					:total="pageTotal"
					@size-change="handleSizeChange"
					@current-change="handlePageChange"/>
			</div>
		</div>

		<!-- 修改或添加弹出框 -->
		<el-dialog :title="titleEdit" v-model="editVisible" width="30%" >
			<el-form label-width="70px">
				<el-form-item label="权限名">
					<el-input v-model="form.privilegeName"></el-input>
				</el-form-item>
                <el-form-item label="权限描述">
					<el-input v-model="form.privilegeDescription" type="textarea"></el-input>
				</el-form-item>
			</el-form>
			<template #footer>
				<span class="dialog-footer">
					<el-button @click="editVisible = false">关闭</el-button>
					<el-button type="primary" @click="saveEdit">保存</el-button>
				</span>
			</template>
		</el-dialog>

		<!-- 分配菜单弹出框 -->
		<el-dialog title="分配菜单" v-model="priVisible" width="30%">
			<el-form label-width="85px">
				<el-form-item label="权限名" >
					<el-input v-model="formPrivilege.privilegeName" disabled></el-input>
				</el-form-item>
				<el-form-item label="分配菜单" > 
					<el-tree
						ref="treeRef"
						:data="data"
						show-checkbox
						node-key="id"		
						:props="defaultProps"
					/>
				</el-form-item>
			</el-form>
			<template #footer>
				<span class="dialog-footer">
					<el-button @click="priVisible = false">关闭</el-button>
					<!-- <el-button type="success" @click="saveGroup">保存</el-button> -->
					<el-button color="#0EB594" @click="saveGroup">保存</el-button>
				</span>
			</template>
		</el-dialog>
	</div>
</template>

<<<<<<< HEAD
<script setup  name="adminList">
=======
<script setup name="adminList">
>>>>>>> c088509ecc2282a34d0b932f6925d649261c336d
import { ref, reactive } from 'vue';
import { ElMessage, ElMessageBox } from 'element-plus';
import { Delete, Edit, Search, Plus } from '@element-plus/icons-vue';
import { getRolePrivilege} from '../../api/privlege';
//是否启用
const  isStart = ref(true)
<<<<<<< HEAD
const small = ref(false)
const size = ref<'default' | 'large' | 'small'>('default')
//开始时间
const username = ref('')
=======
//分页字体
const small = ref(true)
// const size = ref<'default' | 'large' | 'small'>('default')
// const username = ref('')
>>>>>>> c088509ecc2282a34d0b932f6925d649261c336d
//结束时间
const  realName  = ref('')
//分页数据
const query = reactive({
	pageIndex: 1,
	pageSize: 5,
});
//

//表格数据
const tableData = ref();
//总页数
const pageTotal = ref(0);
const multipleTableRef = ref()
const state = reactive({
	multipleSelection:[]
})

// 获取表格数据  分页是数据截取  后台结合一起后  直接返回分页的后的数据
const getData = () => {
    getRolePrivilege({pageCurrent:query.pageIndex,pageSize:query.pageSize}).then(res=>{
        console.log(res,"---resPrivilege---")
        // tableData.value = res.data.
		let start  = (query.pageIndex-1)*query.pageSize;//开始位置
        let end =query.pageIndex*query.pageSize  ;//结束位置 数组的截取的时候 [start,end) suo所以不用-1
        tableData.value = res.data.slice(start,end);
        // tableData.value = res.data;
        pageTotal.value = res.data.length
    })
	
};
getData();
//多选框权限
const handleSelectionChange = (val) => {
  state.multipleSelection = val
}
// 分页导航
const handleSizeChange = (val) => {
  // console.log(`${val} items per page`)
  query.pageSize = val;
  getData()
}
const handlePageChange = (val) => {
	query.pageIndex = val;
	console.log(val,"==")
	console.log(query.pageSize)
	getData()
};



// 删除单个操作
const handleDelete = (index) => {
	// 二次确认删除
	ElMessageBox.confirm('确定要删除吗？', '提示', {
		type: 'warning'
	})
	.then(() => {
		ElMessage.success('删除成功');
		//to.... 传递id 到后台 
		tableData.value.splice(index, 1);
		// 删除成功后
		// getData()
	})
	.catch(() => {});
};
//删除多个数据  to......
const handleAllDelete =()=>{
	// console.log('删除多个')
	console.log(state.multipleSelection,'===拿到所有选择的数据====')
	if (state.multipleSelection.length==0) {
		ElMessage.error('请选择项')
		return
  	}
	// to...
	//axios删除的操作
	

	
}

// 查询操作  to... 需要自己实现与后台交互
const handleSearch = () => {
	query.pageIndex = 1;
	getData();
};

// 表格编辑时弹窗和保存
const editVisible = ref(false);
let form = reactive({
    id:'',
    privilegeName:'',
    privilegeDescription:''
});

// 
let titleEdit = ref('修改')
let isDisable = ref(true)
<<<<<<< HEAD
const open  = (index,row)=>{//index是事件源对象
	if(row){
		isDisable.value=true
		titleEdit.value = "修改"
=======
const open  = (index,row)=>{//index是时间源对象
	if(row){
		isDisable.value=true
		titleEdit.value = "修改";
>>>>>>> c088509ecc2282a34d0b932f6925d649261c336d
		handleEdit(index,row)
	}else{
		//把第一个输出改为可编辑
		isDisable.value=false
		//清空表单中的数据
<<<<<<< HEAD
		titleEdit.value = "添加"
=======
		titleEdit.value = "添加";
>>>>>>> c088509ecc2282a34d0b932f6925d649261c336d
		form.id =''
        form.privilegeName = ''
        form.privilegeDescription =''
		editVisible.value = true	
	}
	console.log('-------测试传值-------')
	// console.log(index,row,index.target.innerText)
	// console.log(index,row)
	// console.log('================')

}
<<<<<<< HEAD
let idx= -1;
const handleEdit = (index,row) => {
=======
let idx = -1;
const handleEdit = (index, row) => {
>>>>>>> c088509ecc2282a34d0b932f6925d649261c336d
	idx = index;
    form.id =row.index
    form.privilegeName = row.privilegeName
    form.privilegeDescription =row.privilegeDescription
	editVisible.value = true;
};
//保存添加或者修改的数据 to---需要重新实现
const saveEdit = () => {
	editVisible.value = false;
	ElMessage.success(`修改第 ${idx + 1} 行成功`);
	tableData.value[idx].index = form.id;
	tableData.value[idx].privilegeName = form.privilegeName;
    tableData.value[idx].privilegeDescription = form.privilegeDescription;
   
};
//分配角色的弹框
const priVisible = ref(false);
const formPrivilege  = reactive({
	privilegeName:''
})
const  treeRef = ref()

//分组回显
const allocationMenu =(index,row)=>{
  console.log(index);
  formPrivilege.privilegeName = row.privilegeName
  priVisible.value = true
	
}
//保存用户分组信息
const  saveGroup=()=>{
	//拿到被选中的用户组
	console.log(treeRef.value.getCheckedNodes(false, false))
	//获取被选中节点的id
	console.log(treeRef.value.getCheckedKeys(false))
   //to ...
}

//树形状控件
const defaultProps = {
  children: 'children',
  label: 'label',
}
// 分组数据目前是死的  可以同axios请求 从后台获取  
const data = [
  {
    id: 1,
    label: '权限系统配置',
    children: [
		{
            id: 2,
            label: '参数信息',
        },
		{
            id: 3,
            label: '咨资料配置',
        },
		{
            id: 4,
            label: '数据库备份',
        },
	],
  },
  
  {
    id: 5,
    label: '用户管理',
    children: [
		{
            id: 6,
            label: '管理员管理',
        },
		{
            id: 7,
            label: '学生管理',
        },
		
	],
  },
  
]

//


//导出数据
import * as XLSX from 'xlsx';

const handleExport = () => {
	// 二次确认删除
	ElMessageBox.confirm('确定要导管理员数据吗？', '提示', {
		type: 'warning'
	})
		.then(() => {
			ElMessage.success('导出成功');
			 //导出数据的实现
			 exportXlsx()
		})
		.catch(() => {});
};

const list = [['序号','用户名', '姓名', '手机', '邮箱', '是否启用', '最后登录时间']];
const exportXlsx = () => {
	console.log('tablev',tableData.value)
    tableData.value.map((item, i) => {
<<<<<<< HEAD
        const arr = [i+1];
=======
        const arr= [i+1];
>>>>>>> c088509ecc2282a34d0b932f6925d649261c336d
        arr.push(...[item.userName, item.name, item.phone, item.email, item.startUsing,item.lastLandingTime]);
        list.push(arr);
    });
    let WorkSheet = XLSX.utils.aoa_to_sheet(list);
    let new_workbook = XLSX.utils.book_new();
    XLSX.utils.book_append_sheet(new_workbook, WorkSheet, '第一页');
    XLSX.writeFile(new_workbook, `表格.xlsx`);
};

</script>

<style scoped>
.handle-box {
	margin-bottom: 20px;
     
}

.handle-select {
	width: 120px;
}

.handle-input {
	width: 196px;
}
.table {
	width: 100%;
	font-size: 14px;
}
.red {
	color: #F56C6C;
}
.blue {
	color: #1296e2;
	font-weight: bold;
}
.mr10 {
	margin-right: 10px;
}
.table-td-thumb {
	display: block;
	margin: auto;
	width: 40px;
	height: 40px;
}
.cell{
    display: inline-block;
    .el-button{
        margin-left: 0px;
    }
}

.el-button-group{
    float: right;
}
</style>
